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METHOD AND SYSTEM FOR PROFILING iTV USERS AND FOR 
PROVIDING SELECTIVE CONTENT DELIVERY 

Related Application 

The present application is a continuation-in-part of Application Serial No. 
09/558,755 filed on April 21, 2000 and entitled "Method and System for Web User 
Profiling and Selective Content Delivery/' which is incorporated herein by 
reference. 

Field 

The present invention relates generally to methods of profiling interactive 
television ("iTV") users, recommending content, and for delivering targeted 
content to users. The present invention can be applied to any content delivery 
medium including but not limited to TV, Internet, and wireless networks. 

Background 

Advertising directed to iTV users (typically video advertisements and 
banner advertisements) is expected to grow rapidly along with the growth of 
iTV, the Internet, and E-commerce activity. Traditional methods of advertising 
have been found to be generally ineffective in drawing responses from users. 
Traditionally, television advertisements and web advertisements have not been 
targeted to particular users but are instead targeted based on the audience 
associated with the television show or Internet content site on which the 
advertisement will appear. 

A more effective means of advertising is advertising targeted to particular 
users. For example, it is known to profile users by determining their 
demographics and interests, and to selectively send advertisements to only those 
users having particular profiles. Information on users can be obtained, e.g., from 
the users themselves through questionnaires. However, in these profiling 
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methods, there is no assurance of user privacy or the accuracy of the profiling 
data. Also, there is no way of accurately matching the advertising to user 
profiles. 

A need exists for a method and system for accurately and anonymously 
profiling users. A need also exists for a method and system for accurately 
matching users of given profiles to content to which they will likely be most 
receptive. 
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Summary 

One embodiment of the invention is a method for profiling an iTV user. In 
this embodiment, the method comprises gathering user-requested content 
information from iTV interactions, correlating content-associated profile 
information from a rating service with the user-requested content information, 
and developing a profile of the user based on the content-associated profile 
information correlated with the user-requested content information. 

Another embodiment of the invention is a set-top box for profiling an iTV 
user. In this embodiment, the invention comprises a memory for storing a 
program and a processor operative with the program to gather user-requested 
content information from iTV interactions, correlate content-associated profile 
information from a rating service with the user-requested content information, 
and develop a profile of the user based on the content-associated profile 
information correlated with the user-requested content information. 

Another embodiment of the invention is a computer readable medium 
comprising instructions for profiling an iTV user by performing the acts of 
gathering user-requested content information from iTV interactions, correlating 
content-associated profile information from a rating service with the user- 
requested content information, and developing a profile of the user based on the 
content-associated profile information correlated with the user-requested content 
information. 

Yet another embodiment of the invention is a method for targeted 
advertising to an iTV user. In this embodiment, the method comprises receiving 
a plurality of advertisements, wherein each of the advertisements includes 
advertising information containing instructions with desired iTV user profiles 
for the advertisement, using a developed user profile along with the desired iTV 
user profiles from the plurality of advertisements to determine which of the 
plurality of advertisements to present to the iTV user as a targeted 

-3- 



WO 02/102030 



PCT7US02/17863 



advertisement, and presenting the targeted advertisement to the iTV user. 

Another embodiment of the invention is a method of profiling an iTV user. 
In this embodiment, the method comprises providing profiles on a plurality of 
iTV programs, monitoring which of said plurality of iTV programs the user 
accesses, and developing a profile of the user based on the profiles of the iTV 
programs accessed by the user. 

Yet another embodiment of the invention is a set-top box for profiling an 
iTV user. In this embodiment, the set-top box comprises a memory for storing a 
program and a processor operative with the program to. monitor which of a 
plurality of programs the user views and develop a profile of the user based on 
predetermined profiles of the programs viewed by the user. 

Another embodiment of the invention is a computer for profiling an iTV 
user. In this embodiment, the computer comprises a memory for storing a 
program and a processor operative with the program to monitor which of a 
plurality of programs the user views and develop a profile of the user based on 
predetermined profiles of the television programs viewed by the user. 

Yet another embodiment of the invention is a system for delivering 
selective advertising to an iTV user. In this embodiment,.the system comprises a 
database containing profile data on a plurality of iTV programs, means for 
monitoring which of said plurality of iTV programs the user accesses, means for 
developing a profile of the user using profile data of the iTV programs accessed 
by the user, and means for matching the user with an advertisement based on 
the developed user profile. 

Another embodiment of the invention is a system for delivering targeted 
advertisements to a client iTV of a user.. In this embodiment, the system 
comprises a local server computer for providing iTV access to the user, a set-top 
box at the client iTV linked to the local server computer, the set-top box 
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including means for monitoring which of a plurality of iTV programs the user 
accesses and means for developing a profile of the user based on predetermined 
profile data of iTV programs accessed by the user, a remote server computer 
linked to said local server computer and including means for providing an 
advertisement to a desired user based on the profile of the desired user and 
means for transmitting said advertisement to said local server computer for 
eventual transfer to the set-top box, and wherein the set-top box further contains 
means for matching the advertisement with the profile of the user. 

Another embodiment of the invention is a computer readable medium 
comprising a program for profiling an iTV user by performing the acts of 
monitoring which of a plurality of ITV programs having predetermined profiles 
the user accesses and developing a profile of the user based on the profiles of the 
ITV programs accessed by the user. 

Yet another embodiment of the invention comprises a computerized 
method of profiling iTV users and selectively delivering content to said users. 
This embodiment comprises providing profiles of a plurality of iTV programs, 
said profiles including demographic data of persons known to have viewed the 
iTV programs, monitoring which of said plurality of iTV programs each of said 
users visits, inferring a profile of each user based on the profiles of the iTV 
programs visited by the user, identifying a target group of said users who would 
be receptive to receiving certain content based on the profiles of the target group, 
and selectively delivering the content to users of the target group. 

Another embodiment of the invention is a program module for a set-top 
box. The program module includes a sniffer for gathering user-requested 
content information from iTV interactions of a user, a profiler for correlating 
content-associated profile information from a rating service with the user- 
requested content information and for developing a profile of the user, and a 
matcher for recommending content to the user based on the profile of the user. 
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Brief Description of the Drawings 

For a fuller understanding of the nature and objects of the present 
invention, reference should be made to the following detailed description taken 
in connection with the accompanying drawings wherein: 

FIGURE 1 is a block diagram illustrating of a representative network in 
which the inventive system may be implemented. 

FIGURE 2 is a block diagram illustrating the architecture of the client in 
one embodiment. 

FIGURE 3 is a display screen shot of a personalized programming guide, 
which also displays a standard programming guide in the bottom portion. 

FIGURE 4 is a block diagram illustrating the ITV or ISP server in an 
embodiment of the invention using two-way communication. 

FIGURE 4a is a block diagram illustrating the client profiling component 
for the embodiment of Figure 4. 

FIGURE 5 is a block diagram illustrating the direct client communications 
component of one embodiment of the invention. 

FIGURE 6 is a screen shot of an exemplary pop-up advertisement in 
accordance with an embodiment of the invention. 

FIGURE 7 is a block diagram illustrating the master server 
synchronization component of an embodiment of the invention. 

FIGURE 8 is a block diagram illustrating the dynamic campaign manager 
of an embodiment of the invention. 

FIGURE 9 is a block diagram illustrating the data analysis system 
component of an embodiment of the invention. 
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FIGURE 10 is a block diagram illustrating the billing component of an 
embodiment of the invention. 
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Detailed Description 
A. General Overview 

The present invention is directed to a method and system for profiling iTV 
users or clients based on their viewing habits, interactions with the iTV, and 
5 Internet surfing habits, and for selectively recommending and delivering 

content, such as advertising or recommended programs, to the users based on 
their profiles. 

FIGURE 1 illustrates a representative network in which the inventive 
system may be implemented in one embodiment The network includes one or 

10 more client machines 10 operated by various individual users. The client 

machines 10 connect to an iTV/ISP server 15 via a communication channel 5, 
which may be a broadcast that is relayed to the clients 10 via a cable connection 
or satellite dish. The communication channel 5, in some embodiments, may 
include a back channel of communication for data going upstream from a client 

15 10 to the iTV/ISP server 15. Such a back channel of communication, also 

represented by communication channel 5 in FIGURE 1, may be a telephone line 
or cable modem, and such a back channel of communication allows two-way 
communication between the clients 10 and the iTV/ISP server 15. In another 
embodiment, which is a one-way communication embodiment, the iTV/ISP 

20 server 15 broadcasts information to the clients 10, but the clients 10 have no way 
of accessing or providing information back to the iTV/ISP server 15. 

The iTV/ISP server 15 may be an iTV server 12, an ISP server 16, or a 
combination of the iTV server 12 and the ISP server 16. The iTV server 12 
provides iTV content that may include programs, advertisements, and 
25 interactive content including the Internet. Such an iTV server may be provided 
by a cable operator, such as RCN. FIGURE 1 plso illustrates an ISP "point-of- 
presence" (POP), which includes an ISP POP Server 16, which may be linked to 
the client for providing access to the Internet. The ISP server 16 may be operated 
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by the same entity as the iTV server 12, by separate entities, or by a joint effort 
between entities. In addition, the iTV server 12 may also function as the ISP 
server 16. In any event, the combined iTV/ISP server 15 represents the 
possibility that these two servers may be linked in some manner so that the client 
10 may have access to interactive television programming and the Internet. It 
should be noted, however, that in some embodiments a client 10 may not have 
Internet access, and in such cases the iTV server 12 may be used without an ISP 
server 16. The Internet service provided through the ISP server 16 may be 
provided through a cable modem or over telephone lines. 

In some embodiments, advertising may be hosted by an ad server 17 that 
is separate from the iTV server 12 that hosts the programming content. In such 
an embodiment, the iTV server 12 may be connected to the ad server 17 by a 
communication channel 14, which may be an Internet connection. The ad server 
17, which may exist in typical iTV or television networks, allows advertisers to 
interact with the iTV server 12 to manage advertising over the television. In one 
embodiment of the invention, a master server 18 may be used to remotely 
manage the ad server 17. The master server 18 may be connected to the ad 
server 14 via communication channel 14, which may be an Internet connection. 
The master server 1 8 may be used by advertisers in an embodiment of the 
invention to determine which ads should be sent to which clients 10. In 
addition, in a television embodiment, the master server 18 communicates this 
information to the add server 17 via the communication channel 14, and the 
information is then forwarded to the iTV server 12 and ultimately the client 10. 
In an Internet embodiment, the master server 18 may communicate this 
advertising information to the ISP server 16, which may then communicate mis 
information to the client 10. The master server 18 may also generate content 
recommendations for clients 10 that are relayed to the iTV server 12 via the ad 
server 17. 

The client machine 10 may be an interactive television set with a set top 
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box or, in other embodiments, a computer. The set top box may be made by 
Motorola and the operating system may be the OpenTV operating system. The 
television itself could be made by any manufacturer, including but not limited to 
Magnavox, Sony, and Toshiba. A representative interactive television set 
5 includes a set top box with a computer processing unit and memory, a remote 
control or keyboard, and a display unit (television set). The screen of the display 
unit is used to present programs, advertising, and other content to the user. A 
graphical user interface (GUI) on the display unit may also be available for the 
user to make programming selections, interact with programs, and access the 

10 Internet. The GUI is supported by the operating system and allows the user to 
use a point and click method of input, e.g., by moving a highlighted area on the 
display screen to a section representing a program at a particular time and 
pressing on the remote control buttons to perform a selection. Also, one or more 
"windows" may be opened up on the screen independently or concurrently as 

15 desired. One predominant GUI is the interactive television guide that allows a 
user to select a program to watch through the vise of a remote control unit. 
Client machines 10 usually access web servers through the connection provided 
by a cable company, such as RCN. 

If the interactive television includes Internet access, the client machine 10 
20 typically may include a browser, which is a known software tool used for 

accessing the Internet. Representative browsers include Netscape Navigator and 
Microsoft Internet Explorer, although other browsers may be used within the 
scope of the invention. In such an embodiment, the client 10 may communicate 
with the ISP server 16. As is well known, the World Wide Web is the Internet's 
25 multimedia information retrieval system. In particular, it is a collection of 

servers of the Internet that use the Hypertext Transfer Protocol (HTTP), which 
provides users access to files (which can be in different formats such as text, 
graphics, images, sound, video, etc.) using, e.g., a standard page description 
language known as Hypertext Markup Language (HTML). HTML provides 
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basic document formatting and allows developers to specify links to other 
servers and files. These links include "hyperlinks," which are text phrases or 
graphic objects that conceal the address of a site on the Web. 

A user of a client machine 10 having an HTML-compatible browser (e.g., 
Netscape Navigator) can retrieve a Web page (namely, an HTML formatted 
document) of a Web site by specifying a link via the URL (e.g., 
www.yahoo.com/photography). Upon such specification, the client machine 
makes a transmission control protocol/Internet protocol (TCP/IP) request to the 
server identified in the link and receives the Web page in return. 

FIGURE 2 illustrates one embodiment of a client machine 10 that may be 
used within the scope of the invention. In general, the embodiment of FIGURE 2 
may be used in an embodiment in which profiling of the user and selecting 
advertisement or program recommendations are carried out at the client level. 
The embodiment of FIGURE 2 may be used in embodiments with either one-way 
or two-way communications between the client 10 and the iTV/ISP server 15. 
The client component 10 may generaUy be set up with instructions and databases 
to profile users based on their behavior on the iTV, store program, advertising, 
and other content, and match the content with the user's profile. The user's 
profile may be used for targeted advertising or for program recommendations to 
the user. FIGURE 3, which will be discussed in greater detail below, depicts a 
display screen of one potential program recommendation embodiment. The 
client 10 may contain an iTV application layer 20, which may contain the 
standard instructions that allow the user to interact with the iTV, as well as a 
program module 21. The program module 21 may reside within the set top box 
of the client 10 or within a separate component at the client level. 

B. Development of a User Profile 

In the embodiment of FIGURE 2, the program module 21 contains a data 
collection component that receives data at the set top box as the result of a user 
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interaction with the client device. Typical user interactions include changing the 
channel, turning the client device on or off, viewing show information through 
the programming guide, responding to interactive surveys, surfing the web, or 
sending e-mails, although other types of interactions may also be monitored. 
Such user-requested content information may be used to build a profile. In one 
embodiment, the data collection component may be a sniffer 22 that monitors 
client interactions with the iTV. The sniffer 22 may extract program data as it 
comes into the set top box in order to monitor the user, and such information may 
be stored in an interaction database 25, referred to in FIGURE 2 as programs and 
URL data. In other embodiments/ the sniffer 22 may detect an outgoing Web 
page request from the client 10 and extract the actual URL request. In addition, 
the sniffer 22 may detect other interactions with the iTV client 10, including e- 
mails, or the sniffer 22 may monitor interacts and search for transactional data 
and keywords, such as those used in search engines on the World Wide Web. 
Such information may also be stored in the interaction database 25. 

The profiler component 23 of the invention may then build a user profile 
27 based on the information in the interaction database 25 and data in a local 
categorized program database 26. User profile information may contain, but is 
not limited to, demographic data (such as, e.g., the user's age, gender, income, 
20 and highest attained education level), psychographic data, which reflects the 

user's interests or content affinity (such as, e.g., sports, movies, music, comedy), 
geographic data, and transactional data. In an embodiment using program data 
collected from the sniffer 22, the local categorized program database 26 may 
contain demographic information on some or all of the television programs 
25 available from entities, such as AC Nielsen, that profile television programs 
using panels of viewers having known demographic characteristics. In other 
words, content-associated profile information for various programs may be 
available from a rating service. Program classification, URL classification, and 
profile data may be obtained from any third party vendors, such as but not 
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limited to Neilsen NetRatings. In other embodiments, this data may be 
generated by the system of the invention after profiles are developed as 
described below. By adding a number of users of known demographies, the 
system could be configured to generate the program profile data. Furthermore, 
the overall demographics generated for the other anonymous users in the system 
could be used to fill out gaps in the program database, i.e., for programs having 
no classification data. 

The client profiler 23 extracts from the program database 26 a set of 
demographic data associated with a particular television program request made 
by the user, which may be stored in the interaction database 25. The profiler 23 
also extracts from the program database 26 content affinity or psychographic data 
associated with a program request made by the user. Such content affinity and 
psychographic data may come from a categorized listing of television programs 
that translate a program identifier into content preferences. The information in 
the program database 39 may be downloaded from the iTV server 12 to the set 
top box or client 10 periodically depending on the amount of memory available at 
the set top box. For set top boxes with very little memory, each hour a program 
database containing only the data for the programs shown that hour would be 
sent from the iTV server 12 to the set top box or client 10. It should also be noted 
that the program database 39 may contain, in some embodiments, profile 
information and content affinity information for URL addresses or other client 
interaction data. Such URL information may include demographic or 
psychographic data that has been compiled by an outside source for given URLs, 
and such URL information may be gathered in the same manner as program data 
by the sniffer 22. In addition, the URL information may be used by the profiler 23 
in the manner described above and in more detail below. 

Next, an existing user profile may be accessed from a user profile 
database 27. The demographic and content affinity data for the program request 
or URL request made by the user and the user profile are combined to create an 
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updated inferred user profile using a hybrid averaging algorithm- One example 
of such an algorithm is an algorithm that provides a weighted average of the 
existing user profile data and the data gathered in the current Web browsing 
session. For example, the new user profile data equals the existing user profile 
5 data multiplied by the number of prior user sessions plus the new user profile 
data gathered in the current session, all divided by the sum of the number of 
prior sessions plus one. This is represented in the following equation: 

new user profile = (existing user profile X number of prior sessions + new 
user profile)/ (number of prior sessions + 1). 

10 If a user is new and no user profile exists, a profile may be created based 

on the zip code corresponding to the physical location of the client 10. Zip Code 
data can also be used to supplement the demographic data supplied by a 
demographic information provider, such as AC Nielsen. The demographic data 
supplied by AC Nielsen may be based on the average demographics of people 

15 viewing a particular program or, in the case of URLs, the demographic data may 
be based on the average demographics of the people viewing a particular URL. 
Other data services, such as Claritas, provide demographics that are based on 
cluster analysis of people by geographic area. Using both a content-based source 
and a geographic-based source of demographics may lead to greater accuracy in 

20 profiling. 

As previously discussed, television program profiles or URL profiles 
available from, e.g., AC Neilsen, are stored in the local categorized program 
database 26. These program profiles are classified along multiple psychographic 
and demographic categories. Throughout this specification, the term "content- 
25 associated profile information" will be used to refer to psychographic and 

demographic information, or to psychographic or demographic information. As 
examples of possible types of content-associated profile information that may be 
used, the following demographic and psychographic categories can be used: 
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Demographir r ategories 
Gender: 

Male 

Female 

5 Age: 

0-11 
12-17 
18-20 
21-24 

10 25 - 34 

35-49 

50-54 

55-64 

65-99 
15 Income: 

0-24,999 

25,000 - 49,999 

50,000 - 74,999 

75,000-99,999 
0 100,000 - 149,000 

150,000 and up 
Education: 

Some High School 
High School Graduate 
> Some College 
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Associates Degree 
Bachelor's Degree 
Post Graduate 
Occupation: 
5 Administrative or Clerical 

Craftsman 
Educators 
Executive 
Laborer 
10 Homemaker 
Military 
Professional 
Sales 
Service 

15 Student 
Technical 
Self-employed 
Retired 

Race: 

20 Hispanic 

Non-Hispanic 
African American 
Caucasian 
Asian 

25 Native American 
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Psvcfrographi c Categ ories 
Entertainment: 

Movies/Film 
5 Theater 

TV/Video 
Drama 
Mystery 
Action 

10 Family 
Cartoons 
Sci-Fi 
Comedy 
History 

15 Science 

Soap Opera 
Game Shows 
Music 
Pop 

20 Rock 

Heavy Metal 
Jazz 

Classical 
Opera 

25 Rap/Hip Hop 
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R+B 
Blues 
Country 
Dance 

5 Games 
Toys 
Travel: 

Air 

Car Rental 
10 Lodging 

Reservations 
Maps 

Finance/Investments: 
15 Banking 
Brokers 
Quotes 
Insurance 
Mortgage 
20 Sports: 

Auto Racing 
Baseball 
Basketball 
Fantasy Sports 
25 Football . 
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Hockey 

Soccer 

Golf 

Tennis 
Recreation & Hobbies: 

Cycling 

Golf 

Hiking 

Sailing 

Snow Sports 

Surfing 

Tennis 

Home & Garden 
Pets 

Genealogy 
Photography 
Games 
Toys 

Auto: 

Trucks 
SUV 

Sports car 
News and Information: 
Magazines 
Weather 
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Politics: 

Democrat 
Republican 

E-shopping: 
5 Groceries 
Furniture 
Auctions 
Cards/Gifts 
Apparel 
10 Books 
Music 
TV/Video 
Software 

E-pur chasing 
15 Computers 

Software 

Science 

Employment 

Education 
20 Health & Fitness 

Medical 

Pharmacy 

Dating/Single 

Advice 
25 Beauty 
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Weddings 
Maternity 

Spirituality /Religion 

Astrology 

Discount 

Luxury 

Child 

Teens 

College Age 
Over 18 

Spanish Language 

For each viewing of a program having a stored profile, the program 
profile may be averaged or combined into the user's profile from the user profile 
database 27 as previously discussed. In other embodiments, the user's profile is 
updated with program profile information when a program is viewed for 
certain period of time, such as 20 minutes or more. Similarly, for each visit to 
Web site having a stored profile, the profile l^^atV^ site isaveraged or 
combined into the user's profile as previously discussed. The profiles include 
rating in each category that reflects the interest in the category of persons who 
access the television program or Web site. 

Each rating is accompanied by a confidence measure, which is an estimate 
of the accuracy of the rating. The confidence number is determined by analyzing 
the program or Web site and rating it on the type and specificity of content, with 
narrower and more singular content providing a higher confidence number. 
When the confidence measure in a particular category is below a predetermined 
threshold, information from other user profiles may be used to provide a more 
accurate rating in a process referred to as "profile completion." 
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An example of a user's profile is shown below. The first number in each 
category indicates the rating for that category. The ratings number is a 
percentage of a maximum rating, representing the degree of the user's affinity to 
the category. In the example below, the ratings number ranges from 0 to 100 
with higher numbers indicating greater affinity. The second number in each 
category (in parenthesis) represents the confidence level in the rating for that 
category. 



User Profile 


User 
ID 


Sports 


Finance 


Movies 


Music 


TV 




Health 


Gardening 


1 


10.0 (.75) 


25.0 (.15) 


0.0 (1.00) 


0.0 (.28) 


0.0 (1.00) 




50.0 (.77) 


85.0 (.82) 



Suppose the confidence threshold is defined to be .50 such that confidence 
is insufficient in any rating that has a confidence measure less than .50. For the 
user profile in the example table shown above, there is insufficient confidence in 
the ratings for the finance and music categories. In this situation, the system 
examines profiles of users with similar profiles to improve the accuracy of the 
ratings in those categories with low confidence measures. 

A clustering algorithm can be used to find profiles that are similar to the 
profile of the current user. In judging the similarity between profiles, the 
confidence measures are ignored and the profiles are treated as n dimensional 
ratings vectors. A simple clustering algorithm is used based on the distance 
between vectors wherein all users whose profiles are within a certain distance of 
the subject user profile are collected. Then, the weighted average of all of the 
profiles in the collection is calculated to get an ideal profile for comparing to the 
subject user profile. If the ideal profile has a rating for the category in question 
that has an acceptable confidence measure, then this rating (and the 
accompanying confidence measure) replaces the corresponding rating in the 
subject user profile. In this way, parts of the user profile that have low 
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confidence ratings are "completed" or "filled-in." An example is shown below. 



10 



15 



Grou P similar profiles to generate an ideal profile to be used to complete the user's profile 



User ID 


Profile 


1 


10.0 (.89), 21.0 (.75), 0.0 (1.00), 17.0 (.74), 0.0 (1.00), .. 


....,52.0 (.64), 95.0 (.90) 


2 


12.0 (.77), 5.0 (.15), 0.0 (1.00), 12.0 (.85), 0.0 (1.00), ... 


, 40.0 (.84), 90.0 (.75) 


3 


11.0 (.81), 20.0 (.77), 0.0 (1.00), 0.0 (1.00), 0.0 (1.00), .. 


75.0 (.77), 81.0 (.73) 


4 


10.0 (.56), 25.0 (.68), 4.0 (.27), 11.0 (.77), 0.0 (1.00), .... 


....,55.0 (.80), 85.0 (.85) 


5 


12.0 (.75), 22.0 (.77), 0.0 (1.00), 10.0 (.83), 2.0 (.30), .... 


....,60.0 (.41), 80.0 (.45) 






Ideal 
profile 


11.0 (.76), 21.1 (.62), 0.9 (.85), 9.4 (.84), 0.5 (.86) 


...,55.8 (.69), 87.1 (.74) 



In the example above, the ideal profile is calculated in the following 
manner. The rating for each category in the ideal profile is calculated by 
multiplying the rating times the confidence measure for each user. These 
products are then added across users in each category. This sum is then divided 
by the sum of the confidence measures added across users in the category. In 
mathematical terms, R idealJ = X R y Qj / 2C y , where R idea i d - is the raring for the ideal 
profile in category j, Ry is the rating in category j for user i, Qj is the confidence 
measure in category j for user i and the sum is taken over i as i ranges from 1 to 
n, which is 5 in this example. The confidence measure for each category in the 
ideal profile is calculated by taking the average of the confidence measure across 
users in the same category, Qdeaij-EQ/n, where is the confidence measure 
for category j in the ideal profile, Qj is the confidence measure in category j for 
user i, and the sum is taken over i as i ranges from l.to n, which is 5 in this 
example. 



The ideal profile is used to complete the subject user profile. In the 
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example described above, there was insufficient confidence in the ratings for the 
user in the finance and music categories. Users having similar profile ratings to 
the user were found to have a finance category rating of 21.1 with a confidence 
measure of .62. Since the confidence threshold was defined to be .50, it is 
5 possible to use the ideal profile finance rating of 21.1 (.62) to replace the user's 
finance category rating of 25 (.15). Similarly, the music category rating for 
similar user profiles was found to have a rating of 9.4 with a confidence measure 
of .84. This is greater than the threshold and is used to complete the subject user 
profile. The music category computation illustrates how the system is able to 
10 advantageously infer that the user may have an interest in the category despite 
the fact that he or she has not visited any ITV programs related to that category. 
The completed subject user profile now appears as follows: 



•Completed' User Profile 


User 
ID 


Sports 


Finance 


Movies 


Music 


TV 




Health 


Gardening 


1 


10.0 (.75) 


21.1 (.62) 


0.0 (1.00) 


9.4 (.84) 


0.0 (1.00) 




50.0 (.77) 


85.0 (.82) 



In order to protect the privacy of users, the system may not keep data on 
15 which programs have been viewed or which Web sites have been visited by 
users for any long term period. Once data in the interaction database 25 has 
been used for updating a user profile, it is erased. Thereafter, it may not be 
possible to match users with particular programs viewed or Web sites visited. 

FIGURES 4 and 4a depict an embodiment of the invention that may be 
20 used where two-way communications between the client 10 and the iTV/ISP 

server 15 are possible. In the embodiment of FIGURES 4 and 4a, the sniffer and 
profiler exist on the server level at the iTV/ISP server 15, which, for 
simplification, is depicted as the ISP P.O.P. server 16 in FIGURES 4 and 4a. 
Referring to FIGURE 4a, the data collection component in this embodiment is the 
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sniffer, which resides in the ISP server 16. This sniffer may function in the same 
manner as described above in connection with FIGURE 2, and may generally 
detect and store the user's program or URL requests if such requests pass 
through the ISP server 16. Such information may be stored in the user ID and 
URL database 30 of FIGURE 4a. Because multiple clients 10 may be connected to 
the server 16 in this embodiment, the user's IP address or iTV address may be 
stored in the database 30. Because IP addresses are typically assigned 
dynamically, they are not necessarily the same every time a client logs into the 
ISP. To correlate an IP address with the associated client 10, the data collection 
component queries an IP address to anonymous user ID (AID) cross-reference 
table stored in another database at the ISP server 16. It then stores the User ID 
and URL/program information in the database 30. 

The profiler component of FIGURE 4a also works in a similar manner to 
that of the profiler 23 of FIGURE 2. The profiler of FIGURE 4a gathers a user's 
ID and URL or program data from the database 30 and develops a user profile 
using the localized categorized data in database 32, which may contain 
demographic and/or psychographic data for URLs and/or programs similar to 
that of program database 26 of FIGURE 2. The user's profile may be generated 
in a similar manner to that described above, and the user's profile along with ID 
may be stored in the local user profile database 34 in the ISP server 16. 

It should be noted that other embodiments may also be used when two- 
way communications are possible. In one such embodiment, the sniffer 22 and 
profiler 23 may function at the client level as in FIGURE 2, and the user profile 
may be periodically sent back to the user profile database 34 on the server level 
(iTV server 12 or ISP server 16). The server level may then contain the profiles of 
all users that receive content from that server. In still other embodiments, the 
sniffer 22 and profiler 23 may exist at both the client level and at the server level. 
In one embodiment, the sniffer 22 and profiler 23 at the client 10 may develop a 
profile for television programs, while a sniffer and profiler at the server level 
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may develop profiles based on URL requests, e-mails, or other information. In 
such an embodiment, the profiles at the client level and server level may be kept 
separate or may be combined into a single profile. 

C. Recommendations and Targeted Advertising 

In accordance with one embodiment of the invention, the system may 
selectively deliver content, e.g., advertisements, program recommendations, or 
the like, to users based on the profiles inferred in the manner described above. A 
personalized agent, or matcher, may make recommendations of content, such as 
programs, to a user based on the user's profile and history or based on other 
users' profiles or histories. In one embodiment, the iTV server 12 broadcasts 
information to each of the clients 10 connected to that service, and the content, 
which may include programs, may be stored in the program database 26 or in 
the local ad database 28. In general, the client 10 uses the profile stored in the 
profile database 27 to filter out content being sent from the iTV server 12 and to 
recommend or retrieve content that appears to be suited to the user. A variety of 
information may be sent from the iTV server 12 to the clients 10, including 
programs and advertisements. 

In one embodiment, the personalization agent can generate program 
recommendations based on the past viewing behavior of the user. In addition to 
20 program recommendations, an interactive program guide that may appear on 
the user's display when using iTV may be automatically rearranged so that the 
channels or programs that are most commonly watched by the user appear at the 
top of the guide. Typical guides, on the other hand, currently list the channels in 
numerical order or start with the major networks followed by the remaining 
25 channels in numerical order. With current cable systems having in excess of 300 
channels for users to choose from, it can be difficult for users to find information 
on the shows they are interested in if all channels are simply listed in numerical 
order. FIGURE 3 illustrates one embodiment of a display that may be presented 
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to a user to show recommendations, which may be generated by the 
personalization agent. The top portion 31 of the programming guide screen of 
FIGURE 3 shows the recommended content that the user may be most likely to 
be interested in based on the user's profile. In FIGURE 3, a number of sporting 
events are depicted in the 7:00 PM time slot, which may indicate that the user's 
profile shows that the user is interested in sports. This top portion 31 may also 
contain a list of the television stations most commonly watched by the user. The 
bottom portion 33 of the programming guide screen of FIGURE 3 shows the 
standard programming guide in which the programs are listed for each time 
period in numeric order based on the number of the channel. In the depicted 
embodiment of FIGURE 3, the recommended content and the standard 
programming guide (top portion 41 and bottom portion 42) may be included on 
a single screen, although in other embodiments only the top portion 41 may be 
displayed. 

Referring again to FIGURE 2, the matcher 24 or personalization agent that 
may be used to generate content recommendations is depicted on the client 10. 
The embodiment described below is for recommending television programs 
using iTV, although a similar procedure may be used to generate recommended 
Web sites or other content within the scope of the invention. In an iTV 
embodiment, recommendations may be generated whenever the user requests 
one through the iTV graphical user interface, typically a programming guide. 
The request is generally made through the use of an input device such as a 
remote control or a keyboard. Alternatively, recommendations may be 
automatically generated when the user selects the programming guide with the 
remote control. In some cases the guide automatically appears when the user 
turns on the television set. In either embodiment, the recommendation request 
may be sent to the set top box and the iTV client application layer 20 may 
forward the request to the matcher component 24 of the client 10. 

The matcher component 24 may then query the profiler 23 or user profile 
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database 27 to get the user's profile. In addition, the matcher component 24 may 
query the program database 26 to ascertain which programs are currently 
showing or are showing in the near future. The matcher 24 may then find the 
programs that best match the user's interests and return those programs to the 
5 application layer 20, which will send the recommendations to the display screen. 
The program database 26 may contain program information that is downloaded 
from the iTV server 12, as discussed above in connection with the profiler 23. 
Such program information may have associated demographic/psychographic 
information that may be used by the matcher 24 to determine which programs 

10 best match the user's interests based on the user's profile. Recommendations 

may, in one embodiment, be stored in a recommendations database 29, as shown 
in FIGURE 2. It should be noted that certain networks or television shows may 
wish to advertise shows through the use of a recommendation agent. Such 
shows may be recommended to users based on the profiles of the users, and the 

15 networks or shows may therefore have a targeted method of advertising for 

television shows. In addition, Web sites may have a similar method of targeted 
advertising. 

The sniffer 22, profiler 23, and matcher 24 may be used to target content 
for the user based on a variety of factors considered in building a user profile- 

20 Such an approach may provide for an accurate measure of the user's interests, 
and hence for accurate matching using the matcher 23. Novelty of certain 
behaviors of the user may factor into the profile of the user built using the 
method above. For instance, user behavior that is new from what the user has 
done in the past may be built into the user profile. As an example, a user may 

25 watch a boxing match after watching no sporting events for a long period of 

time, and this may be built into the user's profile. Interest in certain behaviors 
may be built into a user's profile through the use of the confidence measure. 
Interest could be measured by length of time spent at a URL address, length of 
time spent viewing a certain program or channel, or repeated visits to the same 
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Web site or television channel. As such, the matcher 24 may use a wide variety 
of behavioral information of the user, and not a single behavior, such as 
purchases of books, to focus in providing content. In addition, the mode the user 
is in when surfing the Web or watching television may be considered. For 
instance, the confidence measure of interest in an activity may be low when the 
user is surfing the Web or television channels. In such cases, the amount of time 
spent on certain Web sites or channels may be comparatively small, and this may 
factor into the user's profile. Similarly, if a user shops frequently using such 
channels on television or Web sites, this may be factored into the user's profile so 
that such content may be recommended to the user. 

Using the methods described above, the matcher 24 may be able to 
recommend content within specific categories for the user. For instance, the 
user's profile may be constructed to include levels of interest for various types of 
sporting activities. The iTV system could be set up to allow the user to request 
channels with sporting activities to view on television or Web sites with sporting 
activities, and the matcher 24 could find sporting activities that the user is more 
likely to enjoy based on that user's profile. Similarly, such a method could bi' 
used for to recommend specific shopping channels or sites to the user. As such, 
the user could be provided with program recommendations within a number of 
categories, including but not limited to sporting activities and shopping. 

In systems where two-way communication is available between the client 
10 and the iTV/ISP server, the above functions for the matcher 24 may be carried 
out at the server level instead of at the client-level. In one embodiment, 
recommendations for a given user may be generated based on the preferences of 
other users with viewing habits similar to that of the user. In such an 
embodiment, the user's profile may be sent to the iTV/ISP server 15 or the 
master server 18 upon a user's request for recommendations. The iTV /ISP 
server 15 or the master server 18 may contain a database of user profiles, and this 
database of user profiles may be used to determine which programs a user is 
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likely to be interested in. Such a program may then be delivered to the client 10. 

Another embodiment of the invention also allows advertisers to target 
advertisements based on the profiles of users. Among other possibilities, such 
targeted advertisements may be banner ads displayed when the user is using the 
5 Internet or television advertisements displayed when the user is viewing 
television. In general, the advertisers may be allowed to select a requested 
profile for users who will receive the advertisements, and the profiles of the 
users may be used to match advertising content to the user's profiles. 

In order to provided for targeted advertisements, in this manner, a 
10 dynamic campaign manager component, as shown in FIGURE 8, may reside on 
the master server 18. Such a master server 18 and dynamic campaign manager 
may provide a portal to the system for advertisers (i.e., ad buyers) to select a 
targeted audience for a particular advertising campaign. In choosing the target 
audience, the advertiser is given various options regarding the demographic and 
15 psychographic characteristics of the desired audience for the ad. The dynamic 
campaign manager component, which may be an interface program that allows 
an advertiser to select content, takes information entered by an advertiser, 
creates an advertisement profile, and stores this data in an ad campaign database 
60. In an embodiment in which there is one-way communication between the 
20 iTV/ISP server 15 and the client 10, the desired profile from the ad campaign 
database 60 is sent along with the ad to the local ad database 28 (FIGURE 2) of 
the client 10 via the ad server 17, which generally provides an interface for 
advertisers in traditional iTV systems. 

In an embodiment where one-way communication between the client and 
25 the iTV/ISP server 15 is used, the master server 18 of FIGURE 8 may have 

relatively few components. The information in the local ad database 28 is then 
used by the matcher component 24 of the client 10 to find the best ad for the user 
to view. The best ad for the user to view may be selected by the matcher 
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component 24 in the manner described above in connection with providing 
content recommendations. In this embodiment, a large number of 
advertisements may be sent to the client 10, and then the matcher 24 may filter 
those advertisements so that the viewer is provided with the most relevant 
advertisements based on the user's profile. It should be noted that such an 
embodiment may also be used for banner advertisements presented when the 
user is connected to the Internet. For instance, the URLs of a number of banner 
advertisements may be delivered to the local ad database 28 of the client 10, and 
the matcher 24 may then select the most relevant banner advertisements based 
on the profile of the user. FIGURE 6 is a screen shot 50 of a sample banner ad 
pop-up. The pop-up window may include a "close" button, which allows a user 
to dismiss the window if desired. The window size, position, and order in the 
window stack may be remotely configurable. If the user clicks on the banner or 
some link therein (i.e., cUcks-through), that destination is brought up in a 
browser window, and the user is transferred to the site of interest. In such a 
manner, targeted advertisements may be presented to the user. 

Targeted advertising may also be accomplished using other techniques. 
In an embodiment where there is two-way communication between the iTV/ISP 
server 15 and the clients 10, the advertising system may operate in a different 
manner, although it may continue to function as described above. In one 
embodiment, the profiles of a plurality of local users may be stored in a master 
user profile database 50 on the master server 18, as shown in FIGURES 8 and 9. 
This database 50 may be queried by the data analysis system to project the 
number of users of a particular profile that may be available to receive an ad. 
The data analysis system takes advertising profile data from the ad campaign 
database 60 and matches it to user profiles from the master user profile database 
50. Such a master user profile database 50 may contain a number of user 
profiles. In addition, during the course of an advertising campaign, the data 
analysis system may take data from the master client response database 52 
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(FIGURE 9), which includes client response information on content sent to the 
client 10, to refine the user profiles selection. The data analysis system may write 
the results of matches to the advertisement database 62. The master scheduler 
takes data from the advertisement database 62, resolves any conflicts, and writes 
5 the data to the master advertisement delivery database 54, which may be used to 
schedule delivery of targeted advertisements to various users. 

D. Distributed Architecture Embodiment 

A direct client communications component may be used in some 
embodiments of the invention, and in particular in embodiments using two-way 

10 communication between the client 10 and the iTV/ISP server 15. Such a direct 
client communications component may provide a number of services, as 
described below. As illustrated in FIGURE 5, a direct client communications 
component may selectively retrieve content in the form of URLs from a local 
advertisement database 40 on the ISP server 16, and send it to client machines 10. 

15 The content is displayed on the client machine 10 using the URL display 
component as described. 

The direct client communications component associates a client's 
permanent anonymous user ID and the currently assigned IP address and stores 
the data in the IP address to an AID cross-reference table, which allows 

20 identification of a particular client in spite of a changing IP address. The direct 
client communications component also optionally communicates to the ISP 
server 16 the details of a given client's computer configuration (e.g., which 
multimedia plug-ins are installed, the bandwidth of the Internet connection, 
etc.). This information can be used by the system to help ensure that rich-media 

25 content is delivered only to those client machines 10 that have the ability to 
easily and quickly display such content. The direct client communications 
component may also communicate to the client machine 10 the availability of 
any new versions of URL display software and indicate how they can be 
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10 



20 



25 



downloaded. The URL display component can then initiate an automated 
download/install process for the software update if desired by the 



user. 



The URL display component, which may reside on an individual client 
machine 10, may periodically connect to the direct client communications 
component and download a list of URLs (linked to content such as 
advertisements) to be displayed on the client machine 10. The URL display 
component then uses the URLs to retrieve the actual content pointed to by the 
URL, and displays the content on the client machine 10 display. The content 
may be displayed in a non-obtrusive manner, such as the pop-up window of 
FIGURE 6. In this manner, targeted advertising using banner ads or the like may 
be provided in an additional manner to that described above. The URL display 
component may also record feedback information on the user's response to the 
delivered content. This data can include, e.g., how long the advertisement was 
displayed and whether there was a cUck-through by the user. This data is sent to 
15 the direct client communications component on the ISP server 16, which stores it 
in a local client response database 42, as seen in FIGURE 5. This data can be 
used for billing advertisers and/or for advertising campaign result tracking as 
will be discussed below. 



Since the URL display component may reside on the client machine 10, it 
may be desired to make limited resource demands on the client 10 (e.g., on the 
client machine memory, CPU time and monitor space, Internet bandwidth, etc.). 
Accordingly, the URL display component may monitor the Internet connection 
and only download the actual content data (pointed to by the URLs) when the 
connection is idle. Software updates may also be downloaded only when the 
connection is idle. In addition, the URL display component may monitor the 
client machine CPU usage, the unused real estate on the display, the currently 
active application and any other relevant parameters to ensure that the content 
placement (i.e., the pop-up advertisement) and timing is both effective and not 
intrusive or annoying to the user. The URL display component may also 
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monitor the versioning of the files required for software updates and download 
only the software files that have changed. 

The data collection, delivery and display components residing at the ISP 
server 16 and individual client machines 10 described above may be designed to 
5 operate "stand-alone," i.e., independently of and without interaction with the 
master server 18 for at least some period of time. The system, however, may 
synchronize data between the master server 18 and the ISP server 16 from time 
to time as illustrated in FIGURE 7. A master server synchronization component 
residing at the master server 18 and at the POP server 16 periodically retrieves 

10 the local client profile database 34 and integrates the data into the master client 
profile database 50 located at the master server 18. It also retrieves the local 
client response database 42 and integrates the data into the master client 
response database 52. The master server synchronization component also parses 
through a master advertisement delivery database 54 looking for anonymous 

15 user IDs that correspond to the local POP and creates the local advertisement 

delivery database 40 on the ISP POP. It also replicates a master categorized URL 
database 56 on the local categorized URL database 32. 

This distributed architecture greatly reduces the bandwidth requirements 
of the individual ISP POP server 16 as well as the master server 18. In addition, 
20 it significantly enhances the scalability of the overall system. Also, it increases 
the fault tolerance of the overall system. Furthermore, is allows for rapid 
deployment, easy debug and monitoring, resulting in a robust system. 

E. Monitoring of Advertising Campaigns 

In a one-way communication embodiment between the client 10 and the 
25 iTV/ISP server 15, an advertiser may be able to monitor the success of an ad 
campaign by being provided with an approximate number of users with the 
desired profile for the advertisement. In addition, traditional questionnaire 
methods may be used to determine the success of an ad campaign. Such 
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methods may provide the advertiser with some degree of awareness as to the 
success of an ad campaign. 

In other embodiments, such as those with two-way communication 
between the client 10 and the iTV/ISP server, an advertiser can monitor the 
success of a current ad campaign through the dynamic campaign manager 
shown in FIGURES 8 and 9. For example, for the use of banner ads using the 
Internet, the advertiser can monitor the number of times content has been 
delivered as well as the number of click-throughs on that content. In general, the 
advertiser may be given access to the master client response database 52 for an 
ad campaign to determine how many users have viewed advertisements. For 
embodiments with advertisements provided on television, a record of those ads 
viewed by each user may also be maintained in the master client response 
database 52 in a two-way communication embodiment. An advertiser may then 
determine the number of times a certain ad has been viewed by a single user and 
the number of times the ad has been viewed by all users using two-way 
communication systems of the invention. 

The system may also be adaptive in that the advertiser can, if desired, 
change its marketing strategy (e.g., by adjusting the profile of the targeted 
audience) at various points in the campaign to optimize results. Thus, 
campaigns can be altered dynamically based on changing requirements from the 
advertiser or feedback provided by the system. Campaign management by an 
advertiser may be accomplished through a browser-based console through the 
master server 18. The advertiser can use it to define campaigns, provide content, 
and alter target groups. Feedback as to the success rate of an ad campaign that is 
in progress may also accessible using such a console. 

FIGURE 10 illustrates the billing component of one embodiment of the 
invention. Such an embodiment may be used in systems with two-way 
communication between the client 10 and the iTV/ISP server 15, and such an 
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embodiment may be used for billing for television ads and banner ads for the 
Internet. The billing component may reside on the master server 18 and 
monitors the status of an advertising/content campaign, recognizes whether 
certain billing milestones have been met (e.g., whether an ad has been displayed 
a given number of times), and generates actual invoice information to be sent to 
advertisers. The billing component periodically queries the master client 
response database 52 to determine the current status of a particular advertising 
campaign. If predefined billing milestones have been reached, the billing 
component retrieves specific customer (i.e., advertiser) information from the 
advertisement campaign database 60 to generate formatted invoices for billing 
purposes. 

Having described a number of embodiments of the present invention, it 
should be apparent that modifications can be made without departing from the 
spirit and scope of the invention. Accordingly, the drawings and above 
description are to be regarded as illustrative in nature and not in a restrictive or 
limiting sense, with the scope of the invention being indicated in the claims. 
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Claims 

What is claimed is: 

1. A method for profiling an iTV user, comprising: 

gathering user-requested content information from iTV interactions; 

correlating content-associated profile information from a rating service 
with the user-requested content information; and 

developing a profile of the user based on the content-associated profile 
information correlated with the user-requested content information. 

2. The method of claim 1, wherein the content-associated profile information 
contains demographic information. 

3. The method of claim 1, wherein the content-associated profile information 
contains psychographic information. 

4. The method of claim 1, wherein the user-requested content information is 
a program. 

5. The method of claim 4, further comprising receiving a database 
associating a plurality of programs with content-associated profile information of 
viewers of the programs. 

6. The method of Claim 5, wherein said database is developed by a 
television program ratings service. 

7. The method of Claim 5, wherein gathering user-requested content 
information comprises identifying program requests made by the user while watching 
television. 

8. The method of Claim 7, wherein developing a profile of a user comprises 
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combining the profiles of the programs viewed by the user to the existing user profile 
using an averaging algorithm. 

9. The method of Claim 1, further comprising receiving a plurality of 
advertisements along with desired viewer profiles. 

10. The method of Claim 9, further comprising presenting at least one of the 
advertisements based on the user's profile. 

11. The method of Claim 1, further comprising delivering program 
recommendations to the user based on the user's profile. 

12. The method of claim 1, wherein the user-requested content information is 
a program and a URL. 

13. The method of claim 12, further comprising receiving a database 
associating a plurality of programs with content-associated profile information of 
viewers of the programs and associating a plurality of URLs with content-associated 
profile information of visitors to the URL address. 

14. The method of Claim 13, wherein the information in the database is 
developed by a television program ratings service and a Web site ratings service. 

15. The method of Claim 14, wherein gathering user-requested content 
information comprises identifying program requests made by the user while watching 
television and identifying URLs requested by the user. 

16. The method of Claim 15, wherein developing a profile of a user comprises 
combining the profiles of the programs viewed by the user and profiles of the URLs 
accessed by the user to the existing user profile using an averaging algorithm. 

17. A set-top box for profiling an iTV user, comprising: 
a memory for storing a program; and 
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a processor operative with the program to: 

(a) gather user-requested content information from iTV interactions; 

(b) correlate content-associated profile information from a rating service 
with the user-requested content information; and 

(c) develop a profile of the user based on the content-associated profile 
information correlated with the user-requested content information. 

18. A computer readable medium comprising instructions for profiling an iTV 
user by perforrning the acts of: 

gathering user-requested content information from iTV interactions; 

correlating content-associated profile information from a rating service 
with the user-requested content information; and 

developing a profile of the user based on the content-associated profile 
information correlated with the user-requested content information. 

19. A method for targeted advertising to an iTV user, comprising: 

receiving a plurality of advertisements, wherein each of the 
advertisements includes advertising information containing instructions with desired 
iTV user profiles for the advertisement; 

using a developed user profile along with the desired iTV user profiles 
from the plurality of advertisements to determine which of the plurality of 
advertisements to present to the iTV user as a targeted advertisement; and 

presenting the targeted advertisement to the iTV user. 

20. The method of claim 19, wherein the acts of receiving, using, and 
presenting are carried out in a set top box of the iTV user. 
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21. The method of claim 20, further comprising: 

developing the developed user profile by gathering user-requested 
content information from iTV interactions, correlating content-associated profile 
information from a rating service with the user-requested content information, and 
developing the developed user profile based on the content-associated profile 
information correlated with the user-requested content information. 

22. A method of profiling an iTV user, comprising: 
providing profiles on a plurality of iTV programs; 

monitoring which of said plurality of iTV programs the user accesses; and 

developing a profile of the user based on the profiles of the iTV programs 
accessed by the user. 

23. The method of claim 22, wherein the profile of the user contains 
demographic data. 

24. The method of claim 23, wherein said demographic data includes data on 
the user's age. 

25. The method of claim 23, wherein said demographic data includes data on 
the user's gender. -t-- - 

26. The method of claim 23, wherein said demographic data includes data on 
the user's income. 

27. The method of claim 23, wherein said demographic data includes data on 
the user's highest attained education level. 

28. The method of claim 22, wherein the profile of the user contains 
psychographic data. 
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29. The method of claim 28, wherein said psychographic data includes data 
on the user's interests. 

30. The method of claim 22, wherein providing profiles on a plurality of 
programs comprises providing a database associating each of said plurality of 
programs with demographic characteristics of known persons who have accessed said 
sites. 

31. The method of claim 23, wherein said database is provided by a television 
program ratings service. 

32. The method of claim 22, wherein monitoring which of said plurality of 
programs the user views comprises identifying program requests made by the user 
while watching television. 

33. The method of claim 32, wherein said program requests are identified at 
the set-top box of an interactive television. 

34. The method of claim 32, wherein said program requests are identified at 
the iTV Service Provider point of presence. 

35. The method of claim 34, wherein said program requests are associated 
with a user and stored in a database. 

36. The method of claim 22, wherein developing a profile of a user comprises 
updating an existing user profile. 

37. The method of claim 36, wherein developing a profile of a user comprises 
combining the profiles of programs viewed by the user to the existing user profile 
using an averaging algorithm. 

38. The method of claim 37, wherein said user profile includes data on a 
plurality of demographic categories, each associated with a rating, and the method 
further comprises filling in a value for the rating for any demographic category having 
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a low confidence measure. 

39. The method of claim 38, wherein filling in a value comprises using an 
average rating of persons having similar profiles to that of said user for a category 
having a low confidence measure. 

40. The method of claim 39, wherein said average rating is determined using 
a clustering algorithm. 

41 . The method of claim 22, further comprising erasing records of which 
programs said user has viewed after developing, the user's profile. 

42. The method of claim 22, further comprising matching selective advertising 
to said user based on his or her profile. 

43. The method of claim 42, wherein delivering selective advertising 
comprises transmitting a pop-up advertisement to a display of a television operated by 
the user. 

44. The method of claim 42, wherein delivering selective advertising 
comprises transmitting a video advertisement in the programming stream to the 
display of a television operated by the user. 

45. The method of claim 22, further comprising providing program 
recommendations to the user based on the profile of the laser. 

46. The method of claim 45, wherein the program recommendations are based 
on viewing habits of users with profiles similar to the profile of the user. 

47. The method of claim 45, wherein the program recommendations are 
generated upon a request by the user. 

48. The method of claim 45, wherein the program recommendations are 
generated automatically when the user turns on a television. 
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49. The method of claim 45, wherein the program recommendations are 
presented in the form of a program guide that presents the user's favorite programs 
first. 

50. A set-top box for profiling an iTV user, comprising: 
a memory for storing a program; and 

a processor operative with the program to: 

(a) monitor which of a plurality of programs the user views; and 

(b) develop a profile of the user based on predetermined profiles of the 
programs viewed by the user. 

51. The set-top box of claim 50, further comprising a database associating 
each of said plurality of television programs with demographic characteristics of 
persons viewing said programs. 

52. The set-top box of claim 50, further comprising a database in which 
program requests of the user and associated user information are stored. 

53. The set-top box of claim 50, wherein said processor includes means for 
erasing records of which programs said user has viewed after developing the profile of 
the user. 

54. The set-top box of claim 50, wherein said processor further transmits 
selective advertising to said user based on the profile of the user. 

55. The set-top box of claim 54, wherein said advertising comprises a pop-up 
advertisement to be displayed on an iTV of the user. 

56. The set-top box of claim 50, wherein said set-top box cooperates with an 
iTV operated by the user to display an advertisement on the iTV, said advertisement 
being selected from a plurality of advertisements based on the profile of the user. 
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57. A computer for profiling an iTV user, comprising: 
a memory for storing a program; and 

a processor operative with the program to: 

(a) monitor which of a plurality of programs the user views; and 

(b) develop a profile of the user based on predetermined profiles of the 
television programs viewed by the user. 

58. The computer of claim 57, wherein said computer comprises an ISP point 
of presence server. 

59. A system for delivering selective advertising to an iTV user, comprising: 
a database containing profile data on a plurality of iTV programs; 

means for monitoring which of said plurality of iTV programs the user accesses; 

means for developing a profile of the user using profile data of the iTV 
programs accessed by the user; and 

means for matching the user with an advertisement based on the developed 
user profile. 

60. A system for delivering targeted advertisements to a client iTV of a user, 
comprising: 

a local server computer for providing iTV access to the user; 

a set-top box at the client iTV linked to the local server computer, the set-top box 
including means for monitoring which of a plurality of iTV programs the user accesses 
and means for developing a profile of the user based on predetermined profile data of 
iTV programs accessed by the user; 
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a remote server computer linked to said local server computer and including 
means for providing an advertisement to a desired user based on the profile of the 
desired user and means for transmitting said advertisement to said local server 
computer for eventual transfer to the set-top box; and 

wherein the set-top box further contains means for matching the advertisement 
with the profile of the user. 

61 . The system of claim 60, wherein said local server computer includes a 
local database containing data associating a plurality of iTV programs with 
predetermined profile data on the iTV programs: 

62. The system of claim 60, wherein said means for monitoring comprises 
identifying program requests made by the user while viewing iTV. 

63. The system of claim 60, wherein the set-top box further comprises means 
for monitoring how long the advertisement is displayed to the user. 

64. A computer readable medium comprising a program for profiling an iTV 
user by performing the acts of: 

monitoring which of a plurality of ITV programs having predetermined profiles 
the user accesses; and 

developing a profile of the user based on the profiles of the ITV programs 
accessed by the user. 

65. The computer readable medium of claim 64, wherein the medium 
comprises a removable memory. 

66. The computer readable medium of claim 64, wherein the medium 
comprises a signal transmission. 

67. A computerized method of profiling iTV users and selectively delivering 
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content to said users, comprising: 

providing profiles of a plurality of iTV programs, said profiles including 
demographic data of persons known to have viewed the iTV programs; 

monitoring which of said plurality of iTV programs each of said users visits; 

inferring a profile of each user based on the profiles of the iTV programs visited 
by the user; 

identifying a target group of said users who would be receptive to receiving 
certain content based on the profiles of the target group; and 

selectively delivering the content to users of the target group. 

68. The computerized method of claim 67, further comprising adjusting the 
target group to optimize user responsiveness to the content. 

69. A program module for a set-top box, comprising: 

a sniffer for gathering user-requested content information from iTV interactions 
of a user; 

a profiler for correlating content-associated profile information from a rating 
service with the user-requested content information and for developing a profile of the 
user; and 

a matcher for recommending content to the user based on the profile of the user. 
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